

# Best Available Copy

(12) INTERNATIONAL APPLICATION PUBLISHED UNDER THE PATENT COOPERATION TREATY (PCT)

B3

(19) World Intellectual Property Organization  
International Bureau



(43) International Publication Date  
11 April 2002 (11.04.2002)

PCT

(10) International Publication Number  
WO 02/28162 A2

(51) International Patent Classification: Not classified (81) Designated States (national): AE, AG, AL, AM, AT, AU, AZ, BA, BB, BG, BR, BY, BZ, CA, CH, CN, CO, CR, CU, CZ, DE, DK, DM, DZ, EC, EE, ES, FI, GB, GD, GE, GH, GM, HR, HU, ID, IL, IN, IS, JP, KE, KG, KP, KR, KZ, LC, LK, LR, LS, LT, LU, LV, MA, MD, MG, MK, MN, MW, MX, MZ, NO, NZ, PL, PT, RO, RU, SD, SE, SG, SI, SK, SL, TJ, TM, TR, TT, TZ, UA, UG, US, UZ, VN, YU, ZA, ZW.

(21) International Application Number: PCT/SE01/02862

(22) International Filing Date: 20 December 2001 (20.12.2001)

(25) Filing Language: English

(26) Publication Language: English

(71) Applicant (for all designated States except US): TELEFONAKTIEBOLAGET LM ERICSSON (publ) [SE/SE]; S-126 25 Stockholm (SE).

(72) Inventor; and

(75) Inventor/Applicant (for US only): PLESNER, Erik [DK/DK]; Nordentoft 2, Kaas Mark, DK-7860 Søettrup (DK).

(74) Agent: ERICSSON TELECOM AB; Patent Unit Service and Backbone Networks, S-126 25 Stockholm (SE).

(84) Designated States (regional): ARIPO patent (GH, GM, KE, LS, MW, MZ, SD, SL, SZ, TZ, UG, ZM, ZW), Eurasian patent (AM, AZ, BY, KG, KZ, MD, RU, TJ, TM), European patent (AT, BE, CH, CY, DE, DK, ES, FI, FR, GB, GR, IE, IT, LU, MC, NL, PT, SE, TR), OAPI patent (BF, BJ, CF, CG, CI, CM, GA, GN, GQ, GW, ML, MR, NE, SN, TD, TG).

Declaration under Rule 4.17:

— of inventorship (Rule 4.17(iv)) for US only

Published:

— upon request of the applicant, before the expiration of the time limit referred to in Article 21(2)(a)

[Continued on next page]

(54) Title: PENALTY FREE ADDRESS DECODING SCHEME



WO 02/28162 A2



(57) **Abstract:** The present invention relates to an arrangement for addressing a dual-plane memory. The memory has a first signal input used to activate the memory and a second signal input used to address one of the two memory planes. The arrangement comprises a microprocessor that comprises a chip-select generator having a first chip-select output and a second chip-select output. The first output is connected to the first input of the memory and the second output is connected to the second input of the memory. The outputs and the inputs are connected to each other without time critical element in-between.



- *without international search report and to be republished upon receipt of that report*
- *without classification; title and abstract not checked by the International Searching Authority*

*For two-letter codes and other abbreviations, refer to the "Guidance Notes on Codes and Abbreviations" appearing at the beginning of each regular issue of the PCT Gazette.*

**PENALTY FREE ADDRESS DECODING SCHEME****TECHNICAL FIELD OF THE INVENTION**

The present invention relates to arrangements and methods for change-over between memory planes when updating a 5 program memory.

**DESCRIPTION OF RELATED ART**

When designing products which contain a microcontroller, software SW for this microprocessor has traditionally been contained in either on-chip ROM or off-chip (i.e. separate) 10 erasable EPROM. Recent years, Flash FPROMs has been used to store the SW because FPROMs can be reprogrammed to update the SW in the product. The product can be designed in such a way that it can reprogram itself e.g. via a serial cable, Internet connection or similar. The problem with this self- 15 programming is that the microcontroller can not execute SW located in the FPROM, while the FPROM is being reprogrammed.

This problem can be addressed by copying the update algorithm to RAM and executing it from the RAM, keeping the update algorithm in on-chip ROM or off-chip ROM/EPROM or by 20 using two different FPROMs. In this way the microcontroller can execute code from one FPROM, while updating the contents of the other FPROM.

The later solution also has the advantage that two versions of the application software can be kept at the same time, 25 and if problems arise with the new version, the product can automatically revert to the previous version, and do a new update. In many products the space is limited (e.g. mobile phones) and therefore two FPROM chips are inconvenient. The FPROM chip vendors have addressed the problem by launching 30 the "dual-plane" architecture, which is two independent FPROM chips on the same die. This dual architecture allows

one part of the FPROM to be used for program execution while the other part is being erased or reprogrammed.

The two "planes" share all control, data and addresses pins, and are usually mapped into separate address spaces of the 5 chip. This address distribution implies that the SW has to be compiled/linked to a specific FPROM plane. If a particular version of the SW has been linked for a first address space, it will not be able to work correct in a second address space, and vice versa. This restriction is in 10 general not acceptable, and therefore auxiliary hardware is needed to swap the address-spaces of the two FPROM planes, such that the "active", i.e. currently used, plane always is mapped into one address space and the passive FPROM plane into the other. It is known to use a general purpose I/O pin 15 in conjunction with an XOR gate to toggle the value of the most significant address pin of the FPROM. This address bit of the FPROM distinguishes the two planes of the dual-plane FPROM. Therefore the I/O pin can make either one of the two planes to "switch places" in the memory map of the 20 microcontroller. In the US patent US 6,192,421 is disclosed a program-controlled device with reloading possibility for and change-over possibility to a second operating system without program interruption, where a switchable change-over switch is provided in the address lines. In the US patent 25 however, the switchable change-over switch provided in the address lines causes an additional delay, which causes general performance degradation.

If the microcontroller has a programmable chip-select 30 generator, the problem of swapping the FPROM planes can be solved in the following way: Two separate chip-select lines are programmed to activate on one FPROM plane each. The two chip-select lines are OR'ed together to form the resulting chip select signal for the FPROM, while one of the chip-select signals also are connected to the most significant 35 address line of the FPROM. The problem with this solution is

that the resulting chip select signal of the EPROM usually is on the critical path, and the delay inferred on this signal by the OR-gate causes general performance degradation.

## 5 SUMMARY OF THE INVENTION

The present invention relates to a problem how to change-over between memory planes without performance degradation caused by delay on time critical paths between a microcontroller controlling the memory, and the memory.

10 A purpose with the invention is to accomplish execution of program code in the memory, while the memory is reprogrammed.

The problem is solved by the invention by a microcontroller comprising a chip-select generator, which is used in a way 15 that no time-critical elements need to influence time-critical paths between the microcontroller and the controlled memory.

More in detail, the problem is solved by an arrangement for addressing the memory, which memory is a dual-plane memory 20 having a first signal input used to activate the memory and a second signal input used to address one of the two memory planes. The arrangement comprises a microprocessor having a built-in configurable chip-select generator with a first chip-select output and a second chip-select output. The 25 first output is connected to the first input of the memory and the second output is connected to the second input of the memory. The outputs and the inputs are connected to each other without time critical element in-between.

One advantage with the invention is the possibility to 30 download a new version of software to a product, without performance has to be compromised.

Another advantage with the invention is that software can be compiled/linked in the same way, no matter if it is downloaded to a first or second plane in the memory, and without performance has to be compromised.

5 Yet another advantage with the invention is that it accomplish high performance, without increasing the component cost.

The invention will now be described more in detail with the aid of preferred embodiments in connection with the enclosed  
10 drawings.

#### **BRIEF DESCRIPTION OF THE DRAWINGS**

Figure 1 shows a block schematic illustration of a memory configuration according to the invention, comprising a microprocessor controlling a dual-plane memory.

15 Figure 2 shows a memory map comprising two planes of the dual-plane memory, each of which plane is either active or inactive.

Figure 3 shows a flow chart illustrating a method used to program the microprocessor in accordance with the invention  
20 when the polarity of CS1 is changeable.

Figure 4a and 4b show flow charts illustrating methods used to program the microprocessor in accordance with the invention when the polarity of CS1 is fixed.

25 **DETAILED DESCRIPTION OF EMBODIMENTS**

Figure 1 discloses a memory configuration according to the invention. The figure shows a microprocessor MP connected to a dual-plane Flash Programmable Read Only Memory FPROM. The FPROM can be programmed or re-programmed after the chip has  
30 been soldered onto a chip-board. The FPROM comprises a first

signal input CS used to activate the memory and a second signal input A19, which is an address input, used to address either one of two planes of the dual-plane memory. In this example, activation of the address input A(19) represents 5 activation of the nineteenth address bit. The FPROM comprises data access lines D(31:0) and address input lines A(18:0). The build up of the FPROM will be further clarified when the next figure in the patent application is explained. The microprocessor comprises an external bus interface EBI. 10 The bus interface generates signals that control the access to the FPROM. The bus interface EBI comprises a first chip-select output CS0 and a second chip-select output CS1. The first output CS0 of the microprocessor is connected to the first input CS of the FPROM. The second output CS1 of the 15 microprocessor is connected to the second input A19 of the FPROM. The external bus interface EBI is configurable and can be programmed to activate the outputs CS0 and CS1 under predetermined conditions. The microprocessor in figure 1 comprises nineteen address output lines A(20:2) and thirty- 20 two data access lines Dt(31:0). The address output lines A(20:2) of the microprocessor are connected to the address input lines A(18:0) of the FPROM. The data access lines Dt(31:0) of the microprocessor are connected to the data access lines D(31:0) of the FPROM. 25 Figure 2 shows, as an example, a memory map used in the configuration shown above. The figure shows hexadecimal notation of addresses and from now on all addresses will be referred to in the patent description by hexadecimal notation. The full content of the memory map extends from 30 address 00.0000 to address 100.0000. It is to be noted that the memory map shown in figure 2 is the memory map that is seen by the microprocessor MP. A static random access memory SRAM is located between address 40.0000 and 60.0000 of the memory map. The random access memory function as a working 35 memory for the microprocessor MP. The memory map I/O MMIO

starting from address 00.0000 is used to store input/output interface parameters used by the microprocessor. The FPROM that was shown in figure 1 is a so-called dual-plane FPROM that is two independent FPROM chips on the same die. This 5 architecture allows one part of the FPROM to be used for program execution while the other part is being erased or reprogrammed. The two planes share all control, data and addresses pins, and are usually mapped into separate address spaces of the chip. E.g. a dual-plane chip of 4Mbit + 4Mbit 10 FPROM looks like an 8Mbit FPROM chip to the external world. The two planes are mapped into the lower and upper halves of the address space, respectively. The FPROM can also have uneven splits, e.g. 2Mbit + 6Mbit. The location of the two planes in the memory map in this example is disclosed in 15 figure 2. A first plane FP0 is located from address 80.0000 to BF.FFFF. A second plane FP1 is located from address C0.0000 and FF.FFFF.

The above shown address distribution of the FPROM implies 20 that the software has to be compiled/linked to a specific FPROM plane. If a particular version of the software has been linked for the FP1 plane, it will not be able to work correct in the FP0 plane, and vice versa. This restriction is in general not acceptable, and therefore the address- 25 spaces need to be swapped, such that the currently used plane, the so-called active plane, always is mapped into one address space (e.g. 80.0000-BF.FFFF). The currently not used plane, the so-called passive FPROM plane, is in the same way mapped into the other address space (e.g. C0.0000-FF.FFFF).

To always access the "correct" plane, the invention makes 30 use of the external bus interface EBI located in the microprocessor MP. The external bus interface comprises in this example a built-in programmable chip-select generator. The chip-select generator has the ability to assert more than one output at the same time. This ability is present on 35 some off-the-shelf micro-controllers, e.g. ATMEL AT91M40800.

According to the invention, the chip-select generator is configured to always activate the first chip-select output CS0 whenever the FPPROM is to be accessed. Assuming now that FP0 is the plane currently used, i.e. the active plane.

5 Beyond CS0, also CS1 is activated (active "low"). The address range 80.0000 to BF.FFFF is now accessed. If on the other hand FP1 instead is defined to be the plane currently used, i.e. FP1 is the active plane, the chip-select generator is re-programmed to change the polarity of CS1.

10 CS1 now becomes inactive (or active "high") when the FPPROM is to be accessed. In this case the address areas C0.0000 to FF.FFFF will be accessed. In the figure can be seen how the chip-select signals CS0 and CS1 are used to access the planes. When CS0 is activated the memory area M0 is

15 activated. If also CS1 is activated the area M1 is activated and FP0 is selected. If CS1 instead is inactivated, FP1 is selected.

In figure 3 is disclosed a flow chart showing some of the steps used when the chip-select generator is programmed in accordance with the invention and when it is possible to program the generator to change the polarity of CS1. The flow chart is to be read together with the earlier shown figures. The steps are as follows:

- CS0 is programmed to be active "low" covering M0 when accessing the memory. This step is shown in the figure by a block 101.
- After definition of which memory plane FP0 or FP1 that is the active plane, the programming of CS1 starts. This step is shown in the figure by a block 102.
- 30 - If FP0 is defined as the active plane, CS1 is programmed to be active "low" covering M1. This step is shown in the figure by a block 103.

- If on the other hand FP1 is defined as the active plane, CS1 is programmed to be active "high" covering M1. This step is shown in the figure by a block 104.

The way to program the chip-select generator of course 5 contains a manifold of different variations depending on which type of chip select generator that is used. In the micro-controller ATMEL AT91M40800 for example, the chip-select output CS1 referred to above is fixed to be either active "high" or active "low". If the chip-select generator 10 is not able to reprogram the polarity of its outputs, CS1 can be reprogrammed to react on the address range instead. If for example CS1 is fixed active "low" it is possible to change polarity by changing the address area in which CS1 is active. Changing base address for desired plane can do this. 15 A description of this can be found in the description of the microcontroller AT91M40400, Rev. 0768B-09/98. The address range which the chip-select outputs respond to can usually be programmed by writing to a single register. In this way the WRITE operation is atomic and this property solves all 20 problems with consistency of the chip-select logic.

In figure 4 is disclosed a flow chart showing some of the steps used when the polarity of CS1 is fixed. The first two blocks 101&102 of figure 4a and 4b are the same as the blocks 101&102 already shown in figure 3. The flow chart is 25 to be read together with also the earlier shown figures. The steps in figure 4a where CS1 is fixed active "low" are as follows:

- If FP0 is defined as the active plane and CS1 is fixed active "low", CS1 is programmed to cover M1 by programming 30 the address range 80.0000-BF.FFFF which the chip-select outputs respond to. This step is shown in the figure by a block 105.

- If on the other hand FP1 is defined as the active plane and CS1 is fixed active "low", CS1 is programmed to cover M0\M1 i.e. the part of M0 which is not covered by M1, by programming the address range C0.0000-BF.FFFF which the 5 chip-select outputs respond to. This step is shown in the figure by a block 106.

The steps in the flow chart in figure 4b where CS1 is fixed active "high" are as follows:

- If FP0 is defined as the active plane and CS1 is fixed active "high", CS1 is programmed to cover M0\M1 by programming the address range C0.0000-BF.FFFF which the chip-select outputs respond to. This step is shown in the figure by a block 107. 10

- If on the other hand FP1 is defined as the active plane and CS1 is fixed active "high", CS1 is programmed to cover M1 by programming the address range 80.0000-BF.FFFF which the chip-select outputs respond to. This step is shown in 15 the figure by a block 108.

20

Different variations are of course possible within the scope of the invention. The invention can for example be implemented by ASIC-design, ASIC: Application Specific Integrated Circuits. The chip-select generator can be 25 externally located outside the microprocessor. The technique to program the configurable chip-select generator varies depending on which type of chip select generator that is used. The invention is of course not limited to the above described and in the drawings shown embodiments but can be 30 modified within the scope of the enclosed claims.

## CLAIMS

1. Arrangement for addressing a dual-plane memory (FPROM), which memory has a first signal input (CS) used to activate the memory and a second signal input (A19) used to address one of the two memory planes (FP0; FP1), which arrangement comprises a microprocessor (MP) characterized in that the microprocessor comprises a chip-select generator (EBI) having a first chip-select output (CS0) and a second chip-select output (CS1), whereby the first output (CS0) is connected to the first input (CS) and the second output (CS1) is connected to the second input (A19), and that the outputs (CS0, CS1) and the inputs (CS, A19) are connected to each other without time critical element in-between.  
5
- 10 2. Arrangement for addressing a memory according to claim 1, whereby the chip-select generator (EBI) is built-into the microprocessor (MP).
- 15 3. Arrangement for addressing a memory according to claim 1 or 2, whereby the chip-select generator (EBI) is configurable.  
20
- 25 4. Arrangement for addressing a memory according to any of claim 1-3, whereby the second chip-select output (CS1) is arranged to address either one of the two planes (FP0; FP1), depending on which of the two planes (FP0; FP1) that is defined as active plane.
- 30 5. Arrangement for addressing a memory according to any of claim 1-4, whereby the second chip-select output (CS1) is active "low" when a first plane (FP0) of the two planes is defined as active plane and whereby the second chip-select output (CS1) is active "high" when a second

plane (FP1) of the two planes is defined as active plane.

6. Arrangement for addressing a memory according to any of claim 1-5, whereby the second chip-select output (CS1) is programmed to react on a specified address range (80.0000-BF.FFFF; C0.0000-FF.FFFF).
- 5
7. Arrangement for addressing a memory according to any of claim 1-6, whereby the first chip-select output (CS0) is active "low" when the memory is accessed.

1 / 4



Fig. 1

2/4



Fig. 2

3/4



Fig. 3

4 / 4



Fig 4a



Fig 4b

**This Page is Inserted by IFW Indexing and Scanning  
Operations and is not part of the Official Record**

## **BEST AVAILABLE IMAGES**

Defective images within this document are accurate representations of the original documents submitted by the applicant.

Defects in the images include but are not limited to the items checked:

- BLACK BORDERS**
- IMAGE CUT OFF AT TOP, BOTTOM OR SIDES**
- FADED TEXT OR DRAWING**
- BLURRED OR ILLEGIBLE TEXT OR DRAWING**
- SKEWED/SLANTED IMAGES**
- COLOR OR BLACK AND WHITE PHOTOGRAPHS**
- GRAY SCALE DOCUMENTS**
- LINES OR MARKS ON ORIGINAL DOCUMENT**
- REFERENCE(S) OR EXHIBIT(S) SUBMITTED ARE POOR QUALITY**
- OTHER: \_\_\_\_\_**

**IMAGES ARE BEST AVAILABLE COPY.**

As rescanning these documents will not correct the image problems checked, please do not report these problems to the IFW Image Problem Mailbox.